package com.unismc.wixindemo.handler;

import me.chanjar.weixin.common.error.WxErrorException;
import me.chanjar.weixin.common.session.WxSessionManager;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.bean.message.WxMpXmlMessage;
import me.chanjar.weixin.mp.bean.message.WxMpXmlOutMessage;
import me.chanjar.weixin.mp.bean.result.WxMpUser;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.util.Map;

/**
 * 关注事件
 */
@Component
public class SubscribeHandler extends AbstractHandler {

	@Autowired
	private WxMpService wxMpService;

	@Override
	public WxMpXmlOutMessage handle(WxMpXmlMessage wxMessage, Map<String, Object> context, WxMpService weixinService,
			WxSessionManager sessionManager) throws WxErrorException {

		this.logger.info("新关注用户 OPENID: " + wxMessage.getFromUser());
		String[] openId = {wxMessage.getFromUser()};
			wxMpService.getUserTagService().batchTagging(Long.valueOf(2),openId);
		// 获取微信用户基本信息
		try {
			WxMpUser userWxInfo = weixinService.getUserService().userInfo(wxMessage.getFromUser(), null);
			if (userWxInfo != null) {

			}

		} catch (WxErrorException e) {
			if (e.getError().getErrorCode() == 48001) {
				this.logger.info("该公众号没有获取用户信息权限！");
			}
		}

		return null;
	}
}